一 前言

记录javascript语言object类型的一些问题。

   1. typeof []; // object
   2. typeof {};// object
   3. typeof null; //object

这里讲的是第二种情况。

二 正文

1.for...in 会遍历原型链上的属性

class Super{
    constructor(val){
        this.value=val;
    }
};

const suber = {
    value:'suber'
};

suber.prototype = new Super('super');

for(attr in suber){
    const val = suber[attr]
    console.log('attr-val=>',attr,val); //attr-val=> value suber   attr-val=> prototype Super {value: "super"}
}

这个问题很多人都应该知道。解决的办法也很多:
1) 使用hasOwnProperty(attr) 来取自有属性的值
2) 使用Object.keys(object) 来取得所有的自有属性key,然后object[key]来取得value

2.for...in 遍历的顺序不能保证

Properties order in objects is not guaranteed in JavaScript; you need to use an Array.

for...in 遍历的顺序是按道理来讲是按照出现的先后顺序,但是各家浏览器遍历顺序有所不同。

Chrome Opera 中使用 for-in 语句遍历对象属性时会遵循一个规律,它们会先提取所有 key 的 parseFloat 值为非负整数的属性, 然后根据数字顺序对属性排序首先遍历出来,然后按照对象定义的顺序遍历余下的所有属性。其它浏览器则完全按照对象定义的顺序遍历属性。

所以,顺序这种事,还是要用数组来保证。

详细请参考:JS对象遍历顺序

三 后记

参考链接:JS对象遍历顺序


specialCoder
2.2k 声望168 粉丝

前端 设计 摄影 文学